package 常见排序算法;

import java.util.Arrays;

/**
 * @author feng
 * @Date 2021/10/21 8:04
 * 直接插入排序
 * 从后往前寻找插入位置
 */
class InsertSort {
    public static void main(String[] args) {
        int[] array = {1, 10, 3, 2, 5, 7};
        sort(array);
    }

    public static void sort(int[] arr) {
        int j = 0;
        int tmp = 0;
        for (int i = 1; i < arr.length; i++) {
            // 当前需要插入的元素
            tmp = arr[i];
            //查找需要插入的位置(两个元素 -- ,j=-1)
            for ( j = i - 1; j >= 0; j--) {
                if (arr[j] > tmp) {
                    arr[j + 1] = arr[j];
                } else {
                    break;
                }
            }
            arr[j + 1] = tmp;

        }
        System.out.println(Arrays.toString(arr));
    }

}



